// 放置所有的权限控制相关的代码
// 组件里：this.$router js文件中：import router

import router from './store'
import { getToken } from './utils/auth'
import store from './store'
console.log('权限控制代码生效啦')
const WHITE_LIST = ['/login', '/404']

router.beforeEach(async(to, from, next) => {
  // to 去哪里
  // from：从哪里来
  // next：放行函数
  const token = getToken()
  console.log(token)
  if (token) {
    // 有
    next()
    // 在这里触发获取权限数据的 action 函数
    const res_ = await store.dispatch('user/asyncGetUserInfo')
    console.log(res_)
  } else {
    // 没有
    if (WHITE_LIST.includes(to.path)) {
      // 在白名单内
      next()
    } else {
      // 不在白名单内
      router.push('/login')
    }
  }
})
